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Description 

FIELD OF THE INVENTION 

s This invention relates to a framework based on network flows for Dynamic Channel Allocation (DCA) in a mobile 

telephone system. 

i 

BACKGROUND OF THE INVENTION 

10 With increasing loads on mobile radio communication systems, the efficient utilization of the limited radio bandwidth 

becomes increasingly important. Frequency reuse over spatially separated areas has become a common technique 
used to increase system capacity. Fixed Channel Allocation (FCA) systems, where each cell is statically assigned a 
fixed set of frequencies (or channels) that are non-interfering with neighboring sets, do not often utilize the available 
capacity. This is particularly true when the load across cells is uneven. Dynamic Channel Allocation (DCA) strategies, 

15 on the other hand, are more flexible and allow every cell to use any of the global pool of channels, subject to the current 
state of the changing interference constraints. 

In Dynamic Channel Allocation systems that provide increased capacity over FCA, the system has to decide (1) 
what channel to allocate to a new call, and (2) what reconfigurations are to be performed to the current channel allo- 
cations whenever a call completes or whenever the mobiles move. The former is referred to as call admission and the 

20 latter as reconfiguration. 

Several different algorithms for dynamic channel allocation have been proposed in the literature. At one extreme 
are the optimal packing schemes that, for each given configuration, determine the best possible way of accommodating 
all the ongoing calls using as few channels as possible. Such algorithms achieve optimum capacity by definition, but 
do so at the cost of a complexity and expense that prohibits practical implementation. Furthermore, the channel allo- 
cs cation for each configuration of the mobiles is computed anew as the configurations change with time. Each new optimal 
allocation is likely to bear little resemblance to the prior allocation. This may result in a large number of calls being 
reassigned to different channels. The cost of constantly reassigning in a real system may be considerable. Also, there 
may be no feasible way for the system to "migrate 0 from one allocation to the next short of requiring all calls to switch 
to a new channel in a synchronized fashion. 

30 The problems with optimal packing schemes have motivated a number of simplistic dynamic channel allocation 

systems. The simplest of these handles a call admission by having the new call acquire a channel that is not being 
used in "its vicinity", if such a channel exists. Otherwise, the call is blocked. A somewhat more aggressive algorithm 
also allows a new call to acquire a channel by displacing a nearby interferes but only if the displaced call is able to 
acquire another channel not used in its vicinity to thereby restrict the ripple effect of channel reassignments. Most of 

35 these systems deal only with call admissions, and do not consider channel reassignments at call terminations or due 
to mobility. Channel reassignments required due to a handoff from one cell to another are treated as a call termination 
in one cell and as a new call in another. Some variants of the scheme specify an ordering of the channels to be tried 
in sequence. Such ordered schemes perform channel reassignments at call terminations by requiring that the active 
calls in a cell use the topmost available channels according to the channel ordering for the cell. The attractive simplicity 

40 of such schemes comes from enforcing hard constraints on the number of possible reassignments. Even when a few 
extra reassignments may result in a much improved allocation, the algorithms may forbid such a reassignment. Fur- 
thermore, the possibility of exploiting potentially improved reassignments when calls terminate or mobiles move are 
not explored by these algorithms. 

45 SUMMARY OF THE INVENTION 

The invention is based on a new framework for determining dynamic channel assignment based on network flows. 
The invention addresses the disadvantages of the optimal packing schemes, while at the same time bridging the gap 
relative to the simple schemes. In particular, the cost of performing the reassignments is traded off with the benefit of 

50 moving to the new assignment. This framework not only admits the channel assignments generated by prior systems, 
but also permits other assignments if their reassignment cost is not too high. In contrast to the arbitrary reassignments 
generated by optimal packing, the reassignments generated according to the invention have a structure that suggests 
a way to implement the reassignment in practice. 

In addition, the framework according to the invention allows incorporation of many novel features in a natural 

55 fashion. An example is the consideration of the "quality" of the overall assignment as some function of the quality of 
the various individual connections. Most DCA algorithms are insensitive to quality considerations, and usually pick an 
arbitrary feasible assignment. In cases where the algorithm does depend on the quality of the connections, it only 
handles new call admission decisions meaning that the algorithm is forced to be pessimistic. In other words, to minimally 
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impact future call arrivals, a new call is forced to acquire the available channel that is of the least quality acceptable 
to its demands. With the framework according to the invention, a new call initially gets the best possible channel and 
gives it up for a poorer channel only if later arrivals require such degradation. The system is also capable of handling 
capacity restrictions on base stations, minimum SNR requirements of mobiles etc. 

5 The system according to the invention creates a network flow framework with nodes for each mobile unit, each 

base station and each frequency or channel in use between a mobile unit and a base station. The edges between 
nodes include capacity and cost factors. When a new mobile is to be added, a node is added for the mobile together 
with all available paths through frequency nodes and base station nodes. Augmenting paths for the new mobile which 
require shifting previous frequencies or base stations are included. A shortest path algorithm is used to select the 

10 lowest cost (shortest) path for the new mobile if one exists below threshold value. Optionally, noise or other quality 
factors for the paths from mobiles to base station can be included in the cost calculations for the available paths to 
determine the best path available. Since cost and quality factors are included in the path evaluations, the system can 
be used to evaluate network reconfigurations. 

15 BRIEF DESCRIPTIONS OF THE DRAWINGS 

The preferred embodiments are described in the following specification which includes the following drawings 
wherein: 

20 Figure 1 is a diagram illustrating a cell-based, channel reuse model; 

Figure 2 is a diagram illustrating a more permissive reuse model based on communication quality; 

Figure 3 is a diagram illustrating a flow path of a flow framework according to the invention; 

Figure 4 is a diagram illustrating a flow path with capacity and cost associated with edges thereof; 

Figure 5 is a network flow diagram according to the invention; 
25 Figure 6 is a partial network flow diagram illustrating added nodes and edges seeking augmenting paths for addition 

of a new mobile; 

Figure 7 illustrates several possible augmenting flow paths; 
Figure 8 is a flow diagram for the reconfiguration algorithm. 

30 DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Reuse and Interference Models 

The invention will be described according to two different network flow frameworks based on different channel 

35 reuse models. The first of these is the cell based reuse model traditionally employed in FDMA based fixed channel 
allocation as illustrated in Fig. 1 . In the cell based reuse model, the channel reuse criteria is based on the neighborhood 
of the cells. In other words, each cell has a predefined set of neighboring cells, and a channel in use in a particular cell 
may not be reused in any of the cell's neighbors. Cell B 1 is surrounded by neighboring cells B 2 through B 7 . If frequency 
one (designated f 1 7 when used with base station B-j) is used in cell 1 , the same frequency cannot be used in any of 

40 the neighboring cells, but can be used in more remote cells such as f 18 in cell B 8 and f 7 10 in cell B 10 . 

The second reuse model, as illustrated in Fig. 2, is more permissive and permits use of any channel if, and only 
if, the measured noise values between two uses of a channel do not exceed a certain threshold. With the later reuse 
model, interference is decided dynamically based on current conditions. Cells S 7 and B 5 , neighbors of cell B v may 
use the same channel or frequency one (f 1 v fy^and f 18 ) and still not interfere if, for example, they are on opposite 

45 extreme ends of their respective cells. 

In either case, the reuse model being used provides the following basic data: for each pair of ongoing calls, the 
reuse model determines if they would interfere by using the same channel. In addition, the reuse model may provide 
other information depending on the particular metric(s)/cost(s) being used within the general-framework. For example, 
a cost metric may be used to determine channel allocation based on the quality of the current assignment. For this 

so purpose, the reuse model can be used to provide information about the noise or crosstalk that a new connection is 
likely to experience with respect to other uses of the same channel. 

The stricter cell-based reuse conditions limit the ability to make dynamic channel allocations. For example, an 
intra-cell displacement, where a call arrival at a particular cell displaces another call in the same cell, can never occur 
with cell-based reuse conditions. To fully exploit the channel allocating capability of the system according to the inven- 

55 tion, interference-based reuse conditions should be used. 
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The Network Flow Framework 

The network flow framework for dynamic channel allocation according to the invention is illustrated in Fig. 3. The 
terms used in the following sections are taken from standard network flow terminology found, for example, in R. K. 
s Ahuja, T. L. Magnanti, J. B. Orlin Network Flows: Theory, Algorithms and Applications. Prentice-Hall, NJ, 1993. 

A flow network F is a directed graph G(V,E), where V contains two distinguished nodes - a source node s and a 
sink node t. Each edge e = (v, w) in the graph has an associated integer capacity cap(e), and a cost(e). The costs 
satisfy the constraint that the cost of an edge in one direction is the negative of its cost in the reverse direction, i.e. 
cost(v,w) = -cost(w,v). A flow f on a flow network F= G(V,E) is a function on the edges of Fsuch that the flow on each 
10 edge is at most its capacity (f(v,w)< cap (v,w)), where the flow in one direction is treated as negative flow in the reverse 
direction f (v, w) = -f (w, v) and for every node v (except s or 0, the flow into/out of v is conserved ZJ(v,w) = 0). The 
total flow is defined as the flow out of the source s or, equivalent!^ the flow into the sink t. The total cost of the flow is 
defined to be the weighted sum ZJ(e)cos\(e). 

The flow framework used for determining channel allocation according to the invention, can be considered an 
is operational snapshot of the cellular system (i.e. mobile configurations, base station and frequency assignments) at an 
arbitrary point in time t. The configuration at time t is captured by a corresponding flow network P and a flow on it. 
The network and flow are modified at certain trigger points, which correspond to call arrivals, terminations, handoffs, 
etc. The flow network and the flow on it (and consequently the channel assignment determined by the flow network) 
are changed only at the trigger points. Costs on the flow network's edges can change in a more continuous manner, 
20 since they represent the changing quality due to mobility or other reasons. 

The structure of P and is now defined for the configuration of the system at time t. Noise^,?*) defined to be the 
noise that mobile / would see on a communication to a base station /con frequency /, assuming the applicable reuse 
constraints are satisfied. In addition to s and t, the network P contains the following nodes (see Fig. 3) : a node m\ 
corresponding to each active mobile / in the system (1 < /'< B), and a node ^corresponding to each base station (or 
25 cell) k in the system (1 < k< B), and a node for each frequency / supported at base station k. The edges of Pare 
illustrated in Fig. 4. For each mobile /, add an edge from s to n7,of capacity 1 and cost 0. For each base station k, add 
an edge from B h to t of cost 0 and capacity equal to the capacity of k (the number of mobiles it can support at any 
time). Assign the edge (fj k ,B^ a capacity of 1 , and a cost of 0. 

The last class of edges in Fig. 4 go between the mobile nodes and the frequency nodes. For each mobile /, and 
30 frequency /such that mobile /can potentially talk to base station /con frequency / add at most one edge e, where e is 
given by 



if i is free to use j to talk to k, 

if there is at most one interferer on 
frequency j , talking to base station 
2. 

For each such edge e assign a capacity 1 and a cost equal to Noise(e). 

Finally, the costs are adjusted to represent the penalties for reassignments. Let p denote the parameter represent- 
ing the cost of an inter-cell reassignment, where a call is reassigned to another base station. Let a denote the cost of 

45 an intra-cell reassignment, where a call is reassigned to another frequency in the same cell. For each frequency; being 
used in cell k, subtract p from the cost of (f jk ,B k ). For each mobile / currently assigned to base station /con frequency 
/ subtract a from the cost of (m jt fj k ). 

Fig. 5 illustrates a flow network P with multiple flow paths. Mobiles m, and m 2 communicate with base station B 1 
using channel 2 (f 21 ) and channel 3 (f 31 ) respectively. As indicated by the dotted line flow paths mobile m 1 can po- 

50 tentially communicate with base station S r using channel 3 (f 31 ) and mobile m 2 can potentially communicate with the 
base station using channel 2 (f 2t1 ). Mobiles m 3 and m 4 are shown to communicate with base station B 2 via channel 1 
(f 12 ) and channel 7 (f 72 ). Additional potential channels (not shown in Fig. 5) can also be used for mobiles m 3 and m 4 . 
Mobiles m 5 , m & and m 7 communicate with base station B 3 via channels 2, 3 and 4 (f 23 , f 3 3 and f 4 ' 3 ) respectively. 
Other potential channels also exist in a complete system, but, for simplicity, are not shown in Fig. 5. 

55 Although P can become a fairly complex graph in an actual system, the changes in P caused by the various 

triggers described later are very local in nature, and easy to compute. Thus, from an operational point of view, manip- 
ulating Fdoes not pose a serious problem. 

Lastly, f, the flow on P, is defined by the actual channel assignment at time t in a natural fashion - an assignment 



J (m ± , f jk ) , 
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of mobile / to frequency j and base station k corresponds to a unit flow through the path 

5 

Given a flow network F and a flow f on it, a residual graph Roi Fwith respect to / is a flow network with the same 
cost structure as F, and the following capacities: If edge (v, w) had capacity c(v,w) in Fand flow f(v, w), then the capacities 
with respect to R are given by cap R (v,w) - c (v,w) - f(v,w) and cap^,^ = f(v r w). Intuitively, the capacities in R denote 
the unutilized capacities of Fas well as the possibility of pushing backihe flow f. The general strategy for dynamic 
10 channel allocation according to the invention is to compute channel reassignments by finding paths in the residual 
graph through which new flow can be pushed. The new flow will either increase the total flow from s to t (admitting a 
new mobile into the system) or reroute flow internally along a negative cost cycle (improving the current assignment). 

New Call Admission 

15 

The first "trigger" event to consider is the arrival of a connection request from a new mobile. In this case, the goal 
is to admit the new mobile, if possible, incurring as little added cost as possible. This is done by first expanding the 
current flow graph P to include the new mobile and by then find an augmenting path (a path with residual capacity) in 
the residual graph from s to Mhat goes through the new mobile. 

20 Fig. 6 illustrates a few of the additions to the existing network (Fig. 5) as the initial steps in the search for augmenting 

paths. Let m x be the new node added to P reflecting the new mobile. A single edge from s to m x o\ capacity 1 and cost 
0 is then added. Next, edges from m x to the appropriate frequency nodes f jh are added as described in the construction 
of P (Fig. 5) above. A shortest path algorithm is then used to compute a minimum cost augmenting path Pfrom s to t 
that goes through m x . If no such path exists, the new call is declared blocked. On the other hand, if an augmenting 

25 path from s to t exists, it provides, when traversed in reverse, a sequence of realizable reassignments that results in 
a feasible assignment that satisfies reuse constraints. The cost of the augmenting path equals the sum total improve- 
ment or deterioration in the overall assignment as well as the cost of the reassignments (as determined by the user 
specified cost parameters). Conversely, if no such augmenting path exists, then there exists no possible single-chain 
reaction of reassignments that would have admitted the call. Figure 7 illustrates four examples of possible augmenting 

30 paths. Fig. 7(A) illustrates a simple assignment where the added mobile m x is assigned to communicate with base 
station B 1 on frequency f 1v Assume that channel f 1(1 to base station B 1 does not interfere with channel f 1 2 to base 
station B 2 . In this example, the channel is available and no channel reassignment is required. In Fig. 7(B) a reassign- 
ment within the same cell occurs. New mobile m x acquires frequency f 31 and displaces mobile m 2 , which in turn 
acquires frequency f 4 7 . Fig. 7(e) shows a more elaborate set of reassignments that involves a call from mobile m 2 

35 being switched from a saturated base station to a different, neighboring base station B z 

Reconfigurations 

Reconfigurations of channel assignments may be performed at trigger events other than call arrivals. Examples 
40 of such events are call terminations, handoffs, or deterioration of signal quality on one or more links (due to mobility 
or other reasons). Of these, perhaps a handoff is the only event that requires a reconfiguration for continued feasibility 
of the channel assignment. Most dynamic channel allocation algorithms of the past treat handoffs as two distinct events 
- a call termination in one cell followed by a new call arrival in a neighboring cell. With the approach according to the 
invention all of the events for a handoff are under a common framework since a change in quality of a communication 
45 trigger is a reconfiguration. A handoff is considered an extreme case of quality deterioration requiring a reconfiguration. 
In the case of call terminations, a potential exists for an improved set of channel assignments that may become possible 
because of resources freed by the departing call. 

Preferably, channel qualities, particularity noise, is subject to continuous monitoring and is periodically reflected 
in the costs of the edges of the flow graph, in addition, mobility may also cause occasional structural changes in the 
50 graph as mobiles move closer to or further from base stations, interferes, etc. The trigger events for such reconfigu- 
rations could be defined as either a degradation of quality beyond some threshold or the completion of some threshold 
number of call terminations. 

Unlike the case of call arrivals, the maximum flow possible through the flow graph does not increase due to recon- 
figuration changes. However, the cost of the current flow (and the cost of the best possible flow) keeps changing due 
55 to the changes in the edges and edge costs. The following lemma is from standard network flow theory: 

Lemma 1 Let f be a (sub-optimal) flow in a network, and f*the minimum cost flow Then, the flow f*-f can be decomposed 
into a set of cyclic flows along negative cost cycles. 

Thus, the migration from fXo the optimal flow /*, is achieved by finding negative cost cycles in the residual graph 



EP 0 825 794 A2 



of the current flow. Such negative cost cycles, are "cancelled" by pushing flow through it. Physically, this corresponds 
to making the reassignments along the paths of the cycle, just as in the case of the augmenting paths previously 
described. Figure 8 presents a high level pseudocode for Procedure reconfigure. In this procedure, while the quality 
threshold is violated or the termination threshold is reached, the program repetitively cycles through the steps (1) 

s search for a cycle C of negative cost, (2) follow cycle edges in order, assigning and unassigning frequencies, and (3) 
update the flows on the flow graph to reflect new assignments. 

There may be more than one negative cost cycle in a residual graph. One option is to find these in some arbitrary 
order. A shortest path algorithm can be used to find negative cost cycles. However, it may be desirable to find the 
negative cost cycle whose cancelling gives the maximum benefit. Unfortunately, finding the cycle with the most negative 

10 cost is NP-Complete. However, there exist polynomial time algorithms to compute the cycle with the minimum mean 
cost (i.e. cost of cycle/length of cycle) [A.V.Goldberg and RE. Targan Finding Minimum Cost Circulations by Cancelling 
Negative Cycles, Journal of the ACM, 36(4):873-866, 1 989]. In combination with the following Lemma 2, which suggests 
that the number of reassignments involved in any cycle is roughly proportional to the length of the cycle, that the cycle 
that provides the "maximum gain per reassignment" can be found. 

is Lemma 2 Let C be any negative cost cycle of length n. Then, the number of frequency switches by base stations and/ 
or mobiles in the reconfigurations induced by C lies between^-2 and* 

Preemptive Channel Allocations 

20 The previous sections have always assumed non- preemptive assignments, where a call in progress is never 

dropped unless it does not have the resources to continue. Another scenario could be where a call in progress may 
be dropped if the resultant freeing of resources can result in a new configuration that is globally superior in quality. 
Another variation is where new calls that were unable to get resources are allowed to wait in the system to be assigned 
a channel at a later time. The framework according to the invention can be extended to handle such scenarios; and 

25 variants of the algorithms described above can be designed to operate for such situations. 

Conclusion 

This invention presents a new framework, based on network flows, capable of performing on-line dynamic channel 
30 assignment in cellular networks. It provides a graceful tradeoff between capacity maximization and the penalties as- 
sociated with channel reassignment. In addition, the invention provides for optimizing the overall quality of an assign- 
ment according to a cost metric that is quite general and can be parameterized for various purposes. The framework 
handles channel reassignments for new cell admissions call admissions as well as call terminations, handoffs, and 
channel degradations in a uniform manner. There are many variations within the scope of this invention which is more 
35 particularly defined in the appended claims. 



Claims 

40 1. A method for dynamic channel allocation in a mobile communication system wherein mobile units communicate 
with base stations on allotted channels, including the steps of: 

creating a framework for network flows including flowpaths between 

45 nodes representing active mobile units, 

nodes representing base stations, and 

nodes representing channels used between active mobile units and their respective base stations; 



so 



55 



admitting a new call from a mobile unit being added by finding augmenting flowpaths in said framework, each 
such augmenting flowpath passing through 

an added node for said mobile unit being added, 

a node for an available base station, and 



one or more nodes for channels available for communicating between said added mobile unit and said 
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available base stations; 

said augmenting flowpaths including reverse flow paths corresponding to reassignments of channels or base sta- 
tions; and allocating a channel to said new mobile unit being added according to the shortest augmenting path 
through said node for the mobile being added. 

2. A dynamic channel allocation system according to claim 1 including a quality factor in each flow path and wherein 
the flow path allocated for an added mobile unit is highest quality channel available. 

3. A dynamic channel allocation system according to claim 2 wherein said quality factor is determined according to 
noise between channels. 

4. A dynamic channel allocation system according to claim 1 wherein cost factors are included in the flow paths 
between nodes and the addition of a new mobile is blocked where an augmenting path below a predetermined 
cost threshold is not found. 

5. A dynamic channel allocation system according to claim 1 wherein an augmenting path that requires a channel 
reassignment includes a reverse flow from the node of the channel being reassigned to the node for the mobile 
having its channel reassigned. 

6. A dynamic channel allocation system according to claim 1 wherein an augmenting path that involves a base station 
reassignment includes a reverse flow according to the base station reassignment and a reverse flow according to 
the channel reassignment necessitated by the base station reassignment. 

7. A method for dynamic channel allocation in a mobile communication system wherein mobile units communicate 
with base stations on allotted channels, including the steps of: 

creating a framework for network flows including flowpaths between 

nodes representing active mobile units, 

nodes representing base stations, and 

nodes representing channels used between active mobile units and their respective base stations; 

each of said flowpaths including cost factors; and reconfiguring said systems by reassigning channels that result 
in flowpath cost reductions. 

8. The method for dynamic channel allocation according to claim 7 wherein said reconfigurations take place following 
call terminations. 

9. The method for dynamic channel allocation according to claim 7 wherein said reconfiguration takes place following 
handoffs when a mobile unit is transferred to a different base station. 

10. The method for dynamic channel allocation according to claim 7 wherein said reconfiguration takes place in re- 
sponse to signal quality deterioration. 

11. The method for dynamic channel allocation according to claim 7 wherein said cost factors include interchannel 
noise. 

12. A method for performing dynamic channel allocation in a mobile communication system wherein mobile units 
communicate with base stations on alloted channels, the method including the steps of: 

creating a framework for network flows based on an initial state of said mobile communication system, the 
framework including one or more flowpaths; 

admitting a new call from a mobile unit being added by determining one or more augmenting flowpaths in said 
framework modified to reflect the mobile unit being added; and 
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allocating a channel to said new mobile unit being added based on the determined augmenting flowpaths. 

13. The method according to claim 12 wherein said framework for network flows includes nodes for an active mobile 
unit, a base station and an allocated channel in each of said network flows. 

14. The method according to claim 12 wherein said augmenting flowpaths include reverse flowpaths. 

15. A method for performing dynamic channel allocation in a mobile communication system wherein mobile units 
communicate with base stations on allotted channels, the method including the steps of: 

creating a framework for network flows based on a state of said mobile communication system, the framework 
including one or more flowpaths, each of said flowpaths including one or more cost factors; and 

reconfiguring the state of said mobile communication system by reassigning channel assignments so as to 
result in flowpath cost reductions. 

16. The method according to claim 15 wherein said framework for network flows includes a node for an active mobile 
unit, a base station and an allocated channel in each of said network flows. 
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FIG. 3 
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FIG. 5 
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FIG. 8 
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